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Amendments to the Claims : 

This listing of claims will replace all prior versions, and listings, of claims in the application; 
Listing of Claims : 

1 . (previously presented) A system for processing data received in a plurality of 
incoming streams of variable speeds, comprising: 

a memory configured to store data associated with a plurality of incoming streams of 
variable speeds; 

an interface controller comprising a first arbitration element to arbitrate among the 
streams of variable speeds to store the data in the memory; and 

a dispatch unit comprising a second arbitration element to arbitrate among the streams of 
variable speeds to read the data from the memory. 

2. (original) The system of claim 1 s wherein the memory includes: 
a plurality of memory buckets corresponding to the streams, 

3. (original) The system of claim 2 ? wherein the memory buckets have a fixed size. 

4. (original) The system of claim 1, wherein the first arbitration element is 
configured to store a plurality of entries, each of the entries including a stream number that 
identifies one of the streams. 
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5. (original) The system of claim 4, wherein the number of entries in the first 
arbitration element for a particular one of the streams is based on a speed of the stream. 

6. (original) The system of claim 4, wherein the interface controller is configured to: 
read one of the stream numbers from the first arbitration element, 

gather data corresponding to the identified stream, and 
transfer the data to the memory, 

7, (original) The system of claim 6, wherein the interface controller is further 
configured to send a stream identifier with the data transferred to the memory, 

8, (original) The system of claim 7, wherein the memory is further configured to 
sort the data from the interface controller based on the stream identifier. 

9, (original) The system of claim 1 , wherein the first and second arbitration 
elements are synchronized. 

10. (original) The system of claim 1, wherein the second arbitration element is 
configured to store a plurality of entries, each of the entries including a stream number that 
identifies one of the streams. 
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1 1 . (original) The system of claim 10, wherein the number of entries in the second 
arbitration element for a particular one of the streams is based on a speed of the stream. 

12. (original) The system of claim 10, wherein the dispatch unit is configured to: 
read one of the stream numbers from the second arbitration element, 

read data corresponding to the identified stream from the memory, and 
output the data for processing. 

13. (original) The system of claim 1, further comprising: 

flow control logic configured to initiate flow control on the storing of data in the memory. 

14. (original) The system of claim 13, wherein the flow control includes dropping 
data from the stream. 

15. (original) The system of claim 13, wherein the flow control includes causing the 
interface controller to stop storing data from the stream in the memory. 

16. (original) The system of claim 13, wherein the flow control logic includes: 
a buffer configured to temporarily store the data from the interface controller in a 

plurality of entries, 

a counter configured to determine a number of entries in the buffer corresponding to each 
of the streams, and 
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a comparator configured to determine whether to initiate the flow control for each of the 
streams based on the determined number of entries for the stream. 

17. (original) The system of claim 16, wherein the comparator is configured to 
compare the determined number of entries for a stream to a watermark and initiate the flow 
control for the stream when the determined number of entries exceeds the watermark. 

18. (original) The system of claim 17, wherein the comparator is further configured 
to compare the determined number of entries for the stream to a second watermark and drop data 
from the stream when the determined number of entries exceeds the second watermark, 

19. (original) The system of claim 1, wherein each of the streams has an associated 
watermark for use in performing flow control on the storing of data in the memory. 

20. (original) The system of claim 1, wherein each of the streams has two associated 
watermarks for use in performing flow control on the storing of data in the memory. 

21 . (previously presented) A method for processing data received in a plurality of 
incoming streams of variable speeds, comprising: 

storing data from a plurality of variable speed streams in a memory using a first 
arbitration element that arbitrates among the variable speed streams; and 
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reading the data from the memory using a second arbitration element that arbitrates 
among the variable speed streams. 

22. (original) The method of claim 21, wherein the storing includes: 

storing the data in a plurality of memory buckets in the memory based on the streams to 
which the data belongs. 

23. (original) The method of claim 21, further comprising: 

writing a plurality of entries into the first arbitration element, each of the entries including 
a stream number that identifies one of the streams. 

24. (original) The method of claim 23 f wherein the number of entries in the first 
arbitration element for a particular one of the streams is based on a speed of the stream. 

25. (original) The method of claim 23 f wherein the storing includes: 
reading one of the stream numbers from the first arbitration element, 
gathering data corresponding to the identified stream, and 
transferring the data to the memory, 

26. (original) The method of claim 25, wherein the transferring includes: 
sending a stream identifier with the data transferred to the memory. 
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27. (original) The method of claim 26 ? wherein the storing further includes: 
sorting the data based on the stream identifier, 

28. (original) The method of claim 21, wherein the first and second arbitration 
elements are synchronized, 

29 . (original) The method of claim 2 1 , further comprising: 

writing a plurality of entries into the second arbitration element, each of the entries 
including a stream number that identifies one of the streams. 

30. (original) The method of claim 29, wherein the number of entries in the second 
arbitration element for a particular one of the streams is based on a speed of the stream, 

3L (original) The method of claim 29 P wherein the reading includes: 
obtaining one of the stream numbers from the second arbitration element, 
obtaining data corresponding to the identified stream from the memory, and 
outputting the data for processing. 

32. (original) The method of claim 21 9 further comprising: 
initiating flow control on the storing of data in the memory, 

33. (original) The method of claim 32, wherein the initiating includes: 
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temporarily storing the data in a plurality of entries in a buffer, 
determining a number of entries in the buffer corresponding to each of the streams, and 
determining whether to initiate the flow control for each of the streams based on the 
determined number of entries for the stream. 

34. (original) The method of claim 33, wherein the determining whether to initiate 
the flow control includes; 

comparing the determined number of entries for a stream to a watermark, and 
initiating the flow control for the stream when the determined number of entries exceeds 
the watermark, 

35. (original) The method of claim 34, wherein the determining whether to initiate 
the flow control includes: 

comparing the determined number of entries for the stream to a second watermark, and 
dropping data from the stream when the determined number of entries exceeds the second 
watermark. 

36. (original) The method of claim 32, wherein the initiating the flow control 
includes: 

dropping data from the stream, 
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37. (original) The method of claim 32, wherein the initiating the flow control 
includes: 

stopping the storing of data from the stream in the memory, 

38. (original) The method of claim 21, wherein each of the streams has an associated 
watermark for use in performing flow control for the associated stream. 

39. (original) The method of claim 21, wherein each of the streams has two 
associated watermarks for use in performing flow control for the associated stream. 

40. (original) A system for performing flow control on data in a plurality of incoming 
streams of variable speeds, comprising: 

a buffer configured to temporarily store data from a plurality of streams of variable 
speeds in a plurality of entries; 

a counter configured to determine a number of entries in the buffer corresponding to each 
of the streams; and 

a comparator configured to determine whether to initiate flow control for each of the 
streams based on the determined number of entries for the stream. 

41. (original) The system of claim 40, wherein the comparator is configured to 
compare the determined number of entries for a stream to a watermark and initiate the flow 
control for the stream when the determined number of entries exceeds the watermark. 
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42. (original) The system of claim 41 9 wherein the flow control includes dropping 
data from the stream. 

43. (original) The system of claim 41, wherein the flow control includes causing a 
sender of the data to stop outputting data in the stream. 

44. (original) The system of claim 41 , wherein the comparator is further configured 
to compare the determined number of entries for the stream to a second watermark and drop data 
from the stream when the determined number of entries exceeds the second watermark. 

45. (original) The system of claim 40 ? wherein each of the streams has an associated 
watermark for use in performing flow control on the associated stream. 

46. (original) The system of claim 40 ? wherein each of the streams has two associated 
watermarks for use in performing flow control on the associated stream. 

47. (original) The system of claim 40, further comprising: 
a memory configured to store data from the buffer; 

an interface controller having a first arbitration element and configured to output the data 
to the buffer using the first arbitration element; and 
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a dispatch unit having a second arbitration element arid configured to read the data from 
the memory using the second arbitration element 

48, (original) A method for performing flow control on data in a plurality of 
incoming streams of variable speeds, comprising: 

storing data from a plurality of streams of variable speeds in a plurality of entries of a 

buffer; 

determining a number of entries in the buffer corresponding to each of the streams; and 
determining whether to initiate the flow control for each of the streams based on the 
determined number of entries for the stream. 

49, (original) The method of claim 48, wherein the determining whether to initiate 
the flow control includes: 

comparing the determined number of entries for a stream to a watermark, and 
initiating the flow control for the stream when the determined number of entries exceeds 
the watermark. 

50, (original) The method of claim 49, wherein the initiating the flow control 
includes: 

dropping data from the stream. 
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51. (original) The method of claim 49, wherein the initiating the flow control 
includes: 

causing a sender of the data to stop outputting data in the stream. 

52. (original) The method of claim 49 s wherein the determining whether to initiate 
the flow control includes: 

comparing the determined number of entries for the stream to a second watermark, and 
dropping data from the stream when the determined number of entries exceeds the second 
watermark, 

53. (original) The method of claim 49, wherein each of the streams has an associated 
watermark, 

54. (original) The method of claim 49, wherein each of the streams has two 
associated watermarks. 

55 . (original) A system for performing 0ow control on data in a plurality of incoming 
streams of variable speeds, comprising: 

a buffer configured to temporarily store data from a plurality of streams of variable 
speeds in a plurality of entries; 

a counter configured to determine a number of entries in the buffer corresponding to each 
of the streams; and 
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a comparator configured to: 

compare the determined number of entries for a stream to first and second 

watermarks, 

initiate flow control for the stream when the determined number of entries 
exceeds the first watermark, and 

drop data from the stream when the determined number of entries exceeds the 
second watermark. 

56. (previously presented) A network device, comprising: 
an input interface configured to: 

receive a plurality of packets belonging to a plurality of streams of variable speed, 

and 

output the packets based on a first arbitration scheme that arbitrates among the 
streams of variable speed; 
input logic comprising: 

flow control logic configured to initiate flow control on the packets output by the 
input interface, 

a memory configured to store the packets from the input interface, 
a dispatch unit configured to read the packets from the memory based on a second 
arbitration scheme that arbitrates among the streams of variable speed; and 

one or more packet processors configured to process the packets from the dispatch unit. 
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57. (previously presented) A network device, comprising: 

means for receiving a plurality of packets belonging to a plurality of streams of variable 

speed; 

means for storing the packets based on a first arbitration scheme that arbitrates among the 
streams of variable speed; 

means for performing flow control on the storing of the packets; 

means for reading the packets based on a second arbitration scheme that arbitrates among 
the streams of variable speed; and 

means for processing the packets read based on the second arbitration scheme. 

58. (new) The system of claim 1, wherein the first arbitration element is configured 
to arbitrate among the streams of variable speeds to store the data in the memory based on speeds 
of the streams and the second arbitration element is configured to arbitrate among the streams of 
variable speeds to read the data from the memory based on the speeds of the streams. 

59. (new) The system of claim 1 , wherein at least one of the first arbitration element 
or the second arbitration element is configured to be reprogrammed based on an input regarding a 
speed of at least one of the streams. 

60. (new) The method of claim 21 s wherein the storing data includes: 

arbitrating among the variable speed streams to determine data from which of the variable 
speed streams to store based on speeds of the variable speed streams; and 
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wherein the reading the data includes: 

arbitrating among the variable speed streams to determine data from which of the variable 
speed streams to read based on the speeds of the variable speed streams. 

61 . (new) The method of claim 2 1 „ further comprising: 

receiving an input regarding a speed of at least one of the variable speed streams; and 
reprogramming at least one of the first arbitration element or the second arbitration 
element based on the received input. 
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